# SoC-FPGA Design

# Manual

# Real Time Embedded Systems Course

LAP – IC – EPFL

Version 0.3 (Preliminary)

René Beuchat

### 1 Introduction

The development of embedded systems based on chips containing one or more microprocessors and hard-core peripherals, as well as an FPGA part is becoming more and more important. This technology gives the designer a lot of freedom and powerful abilities. Classical design flows with microcontrollers are emphasized with the full power of FPGAs.

Mixed designs are becoming a reality with. One can now design specific accelerators to greatly improve algorithms, or create specific programmable interfaces with the external world.

Two main HDL (Hardware Design Language) languages are available for the design of the FPGA part: VHDL and Verilog. There also exist other tools that perform automatic translations from C to HDL. New emerging technologies like OpenCL allow compatibility between high-level software design, and low-level hardware implementations as:

- Compilation for single or multicore processors
- Compilation for GPUs (Graphical Processing Unit)
- Translation and compilation for FPGAs. The latest models use a PCIe interface or some other way of parameters passing between the main processor and the FPGA

This guide assumes users know how to use QuartusII, NIOSII, Qsys and ModelSim-Altera.

We will be using the Terasic DE1-SoC board: http://de1-soc.terasic.com

### 2 Terasic DE1-SoC board



Fig. 1. Terasic DE1-SoC board

The DE1-SoC board has many features that allow users to implement a wide range of designed circuits. We will discuss some noteworthy features in this guide.

# 2.1 Specifications

### FPGA Device

- Cyclone V SoC **5CSEMA5F31C6** Device
- Dual-core ARM Cortex-A9 (HPS)
- **85K** Programmable Logic Elements
- 4'450 Kbits embedded memory
- 6 Fractional PLLs
- 2 Hard Memory Controllers

### Configuration and Debug

- Quad Serial Configuration device EPCQ256 on FPGA
- On-Board USB Blaster II (Normal type B USB connector)

### Memory Device

- 64MB (32Mx16) SDRAM on FPGA
- 1GB (2x256Mx16) DDR3 SDRAM on HPS
- Micro SD Card Socket on HPS

### Communication

- Two Port USB 2.0 Host (ULPI interface with USB type A connector)
- USB to UART (micro USB type B connector)
- 10/100/1000 Ethernet
- PS/2 mouse/keyboard
- IR Emitter/Receiver

### **Connectors**

- Two 40-pin Expansion Headers
- One 10-pin ADC Input Header
- One LTC connector (One Serial Peripheral Interface (SPI) Master, one I2C and one GPIO interface)

### Display

• 24-bit VGA DAC

### Audio

24-bit CODEC, line-in, line-out, and microphone-in jacks

### Video Input

TV Decoder (NTSC/PAL/SECAM) and TV-in connector

### **ADC**

Fast throughput rate: 1 MSPS

Channel number: 8Resolution: 12 bits

• Analog input range : 0 ~ 2.5 V or 0 ~ 5V as selected via the RANGE bit in the control register

### Switches, Buttons and Indicators

- 4 User Keys (FPGA x4)
- 10 User switches (FPGA x10)
- 11 User LEDs (FPGA x10; HPS x 1)
- 2 HPS Reset Buttons (HPS\_RST\_n and HPS\_WARM\_RST\_n)
- Six 7-segment displays

### Sensors

G-Sensor on HPS

### Power

• 12V DC input

### Block Diagram



Fig. 2. Block Diagram of the DE1-SoC Board

# 2.2 Layout



Fig. 3. Front



Fig. 4. Back

- Green for peripherals directly connected to the FPGA
- Orange for peripherals directly connected to the HPS
- Blue for board control

Manuals and resources are available on the DE1-SoC resources page.

# 3 Cyclone V Overview

This section describes some features of the Cyclone V family of devices. All this information, along with the most complete documentation regarding this family can be found on the <u>Cyclone V Device Handbook</u>, more specifically <u>Volume 3: Hard Processor System Technical</u>

Reference Manual.

# 4 SoC part test

### 4.1 HPS Architecture

To be able to program the ARM9's processors it is almost necessary to have the global view of the HPS architecture.



# 4.2 Hardware development

### 4.2.1 Qsys integration

Starting with **QuartusII** and after creating a project, select **Tools** → **Qsys** 

In **Qsys**, open *Library*  $\rightarrow$  *Embedded Processors*  $\rightarrow$  *Hard Processor System* the window with description of the parameters for the HPS is open.

The FPGA Interface tab allows the access from to the FPGA part with the HPS part.



Apply Update... Delete

With the **PeripheralPin Multiplexing**, some I/O interface can be used by the HPS part or the FPGA part. The selection is done here.

### 4.3 Software development

#### 4.3.1 **ARM DS-5 tools**

They are some differences between the versions of DS-5.

The one installed for the test is:

ARM DS-5 (DS-5 Altera Edition (Evaluation))

Version: 5.18.0

Build number: 5180018

### 4.3.2 Hello World on ARM HPS part

Copy the directory from Altera examples:

C:\altera\13.1\embedded\examples\software

And un-gz the file: Altera-SoCFPGA-HelloWorld-Baremetal-ARMCC.tar.gz

Then un-tar it.

The directory **Altera-SoCFPGA-HelloWorld-Baremetal-ARMCC** can then be copied in the Eclipse WorkSpace and Imported as a new project. The files inside are:

.cproject used by Eclipse.project used by Eclipse

• \*\*\*\*.launch ??

Makefile for the Compiler/Assembler/Linker

An important info is the flag for the cpu: --cpu=Cortex-A9.no\_neon.no\_vfp

• scatter.scat Info for the compiler for the Code, Data, Stack and Heap addresses

in this case in the internal SRAM

# 4.3.2.1 Scatter.scat

```
;*********
; Copyright (c) 2013 Altera All Rights Reserved.
;********
; Scatter-file for OnChip RAM based example
; This scatter-file places application code, data, stack and heap at suitable addresses in the memory map.

; Altera SoC-FPGA has 64kB of internal OnChip RAM

OCRAM 0xFFFF0000 0x10000
{

APP_CODE +0
```

```
{
 * (+RO, +RW, +ZI)
}

ARM_LIB_STACKHEAP OxFFFF8000 EMPTY Ox8000 ; Application heap and stack
{}
}
```

#### 4.3.2.2 Makefile

Makefile for the ARM compiler

```
# Copyright (C) ARM Limited, 2011. All rights reserved.
# This example is intended to be built with the ARM Compiler armcc
TARGET=Altera-SoCFPGA-HelloWorld-Baremetal-ARMCC.axf
CC=armcc
AS=armasm
LD=armlink
AR=armar
# Select build rules based on Windows or Unix
ifdef WINDIR
DONE=@if exist $(1) echo Build completed.
RM=if exist $(1) del /q $(1)
SHELL=$(WINDIR)\system32\cmd.exe
else
ifdef windir
DONE=@if exist $(1) echo Build completed.
RM=if exist $(1) del /q $(1)
SHELL=$(windir)\system32\cmd.exe
DONE=@if [-f$(1)]; then echo Build completed.; fi
RM=rm -f $(1)
endif
endif
all: $(TARGET)
       $(call DONE,$(TARGET))
rebuild: clean all
clean:
        $(call RM,*.o)
        $(call RM,$(TARGET))
hello.o: hello.c
        $(CC) -c -g --cpu=Cortex-A9.no_neon.no_vfp -O0 hello.c
$(TARGET): hello.o scatter.scat
        $(LD) hello.o -o $(TARGET) --cpu=Cortex-A9.no_neon.no_vfp --scatter=scatter.scat
```

### 4.3.3 GPIO access

The references for gpio are:

- http://www.altera.com/literature/hb/cyclone-v/cv\_54022.pdf
- <a href="http://www.altera.com/literature/hb/cyclone-v/hps.html">http://www.altera.com/literature/hb/cyclone-v/hps.html</a>
- Supports up to 71 I/O pins and 14 input-only pins depend on device variant

#### On de1-soc:

- Only 1 Button for HPS GPIO 1
- Only 1 LED for HPS GPIO 1

| Pin Name | HPS GPIO | Register [bit] | Function | Address     | Dir |
|----------|----------|----------------|----------|-------------|-----|
| HPS_KEY  | GPIO54   | GPIO1[25]      | 1/0      | 0xFF20 9000 | In  |
| HPS_LED  | GPIO53   | GPIO1[24]      | 1/0      | 0xFF20 9000 | Out |
|          |          |                |          |             |     |
|          |          |                |          |             |     |

HPS peripherals are mapped to HPS base address space 0xFC00 0000 with 64KB size.

Registers of GPIO0 controller are mapped to the base address 0xFF20 8000 - 0xFF20 8FFF (4KB size)

Registers of GPIO1 controller are mapped to the base address 0xFF20 9000 - 0xFF20 9FFF (4KB size)

Registers of GPIO2 controller are mapped to the base address 0xFF20 A000 - 0xFF20 8FFF (4KB size)

|              |               | http://www.altera.com/literature/hb/cyclone-<br>v/cv 5v4.pdf |  |
|--------------|---------------|--------------------------------------------------------------|--|
| GPIO0        | 0xFF20 8000 - | 0xFF70 8000                                                  |  |
|              | 0xFF20 8FFF   |                                                              |  |
| GPIO1        | 0xFF20 9000 - | 0xFF70 9000                                                  |  |
|              | 0xFF20 9FFF   |                                                              |  |
| GPIO2        | 0xFF20 A000 - | 0xFF70 A000                                                  |  |
|              | 0xFF20 8FFF   |                                                              |  |
| LWFPGASLAVES |               | 0xFF20 0000                                                  |  |
|              |               |                                                              |  |

| gpio0              | 0xFF70 | HPS_GPIO0_ADDRESS                    | HPS_GPIO0_OFFSET               |  |
|--------------------|--------|--------------------------------------|--------------------------------|--|
|                    | 8000   |                                      |                                |  |
| gpio_swporta_dr    | 0      | HPS_GPIO0_GPIO_SWPORTA_DR_ADDRESS    | GPIO_GPIO_SWPORTA_DR_OFFSET    |  |
| gpio_swporta_ddr   | 0x04   | HPS_GPIO0_GPIO_SWPORTA_DDR_ADDRESS   | GPIO_GPIO_SWPORTA_DDR_OFFSET   |  |
| gpio_inten         | 0x30   | HPS_GPIO0_GPIO_INTEN_ADDRESS         | GPIO_GPIO_INTEN_OFFSET         |  |
| gpio_intmask       | 0x34   | HPS_GPIO0_GPIO_INTMASK_ADDRESS       | GPIO_GPIO_INTMASK_OFFSET       |  |
| gpio_inttype_level | 0x38   | HPS_GPIO0_GPIO_INTTYPE_LEVEL_ADDRESS | GPIO_GPIO_INTTYPE_LEVEL_OFFSET |  |
| gpio_int_polarity  | 0x3c   | HPS_GPIO0_GPIO_INT_POLARITY_ADDRESS  | GPIO_GPIO_INT_POLARITY_OFFSET  |  |
| gpio_intstatus     | 0x40   | HPS_GPIO0_GPIO_INTSTATUS_ADDRESS     | GPIO_GPIO_INTSTATUS_OFFSET     |  |
| gpio_raw_intstatus | 0x44   | HPS_GPIO0_GPIO_RAW_INTSTATUS_ADDRESS | GPIO_GPIO_RAW_INTSTATUS_OFFSET |  |
| gpio_debounce      | 0x48   | HPS_GPIO0_GPIO_DEBOUNCE_ADDRESS      | GPIO_GPIO_DEBOUNCE_OFFSET      |  |
| gpio_porta_eoi     | 0x4c   | HPS_GPIO0_GPIO_PORTA_EOI_ADDRESS     | GPIO_GPIO_PORTA_EOI_OFFSET     |  |
| gpio_ext_porta     | 0x50   | HPS_GPIO0_GPIO_EXT_PORTA_ADDRESS     | GPIO_GPIO_EXT_PORTA_OFFSET     |  |
| gpio_ls_sync       | 0x60   | HPS_GPIO0_GPIO_LS_SYNC_ADDRESS       | GPIO_GPIO_LS_SYNC_OFFSET       |  |
| gpio_id_code       | 0x64   | HPS_GPIO0_GPIO_ID_CODE_ADDRESS       | GPIO_GPIO_ID_CODE_OFFSET       |  |
| gpio_ver_id_code   | 0x6c   | HPS_GPIO0_GPIO_VER_ID_CODE_ADDRESS   | GPIO_GPIO_VER_ID_CODE_OFFSET   |  |
| gpio_config_reg2   | 0x70   | HPS_GPIO0_GPIO_CONFIG_REG2_ADDRESS   | GPIO_GPIO_CONFIG_REG2_OFFSET   |  |
| gpio_config_reg1   | 0x74   | HPS_GPIO0_GPIO_CONFIG_REG1_ADDRESS   | GPIO_GPIO_CONFIG_REG1_OFFSET   |  |

|  |  |  | 1 1 |
|--|--|--|-----|
|  |  |  | 1 1 |

# 4.3.3.1 Library installation

C:\altera\13.1\embedded\ip\altera\hps\altera\_hps\hwlib

**HERE** 

#### 4.3.3.2 Reference files

| hps.h |  |
|-------|--|
|       |  |
|       |  |
|       |  |
|       |  |
|       |  |
|       |  |
|       |  |

**4.3.3.2.1 Titre**5 **4.3.3.2.1.1 Titre6**4.3.3.2.1.1.1 Titre7
4.3.3.2.1.1.1.1 Titre8
4.3.3.2.1.1.1.1 Titre9

### References

- Altera, Cyclone V Devices documentation, <a href="http://www.altera.com/literature/lit-cyclone-v.jsp?ln=devices\_fpga&l3=Low-Cost%20FPGAs-Cyclone%20V%20%28E,%20GX,%20GT,%20SE,%20SX,%20ST%29&l4=Documentation">http://www.altera.com/literature/lit-cyclone-v.jsp?ln=devices\_fpga&l3=Low-Cost%20FPGAs-Cyclone%20V%20%28E,%20GX,%20GT,%20SE,%20SX,%20ST%29&l4=Documentation</a>
- Cyclone V Device Handbook Volume 3: Hard Processor System Technical Reference Manual http://www.altera.com/literature/hb/cyclone-v/cv 5v4.pdf
- Cyclone V Hard Processor System User Guide <a href="http://www.altera.com/literature/hb/cyclone-v/cv">http://www.altera.com/literature/hb/cyclone-v/cv</a> 5v4 08.pdf
- Cyclone V, Device Datasheet
   <a href="http://www.altera.com/literature/hb/cyclone-v/cv">http://www.altera.com/literature/hb/cyclone-v/cv</a> 51002.pdf
- Cylone V HPS addresses
   http://www.altera.com/literature/hb/cyclone-v/hps.html
- Cyclone V Device Handbook Volume 1: Device Interfaces and Integration http://www.altera.com/literature/hb/cyclone-v/cyclone5 handbook.pdf

- Cyclone V, Device Overview
   http://www.altera.com/literature/hb/cyclone-v/cv\_51001.pdf
- SoCAL documentation (html), The Altera SoC Abstraction Layer (SoCAL) API Reference Manual file:///C:/altera/13.1/embedded/ip/altera/hps/altera\_hps/doc/socal/html/index.html
- Altera HWLIB, The Altera HW Manager API Reference Manual file:///C:/altera/13.1/embedded/ip/altera/hps/altera hps/doc/hwmgr/html/index.html
- Cyclone V, A Bare-Metal Debugging using ARM DS-5 Altera Edition http://www.youtube.com/watch?v=CJ0EHJ9oQ7Y
- Linux Kernel Debug using ARM DS-5 Altera Edition http://www.youtube.com/watch?v=QcA39O6ofGw
- FPGA-adaptive debug on the Altera SoC using ARM DS-5 http://www.youtube.com/watch?v=2NBcUv2TxbI
- A Look Inside: SoC FPGAs Introduction (Part 1 of 5)
   http://www.youtube.com/watch?v=RVM-ESUMOMU (Part 1 of 5)
   http://www.youtube.com/watch?v=Ssxf8ggmQk4 (Part 2 of 5)
   http://www.youtube.com/watch?v=cWlaqt2RU84 (Part 3 of 5)
   http://www.youtube.com/watch?v=gUE669XKhUY (Part 4 of 5)
   http://www.youtube.com/watch?v=NxZznvf5EKc (Part 5 of 5)
- DS-5 Altera Edition: Bare-metal Debug and Trace http://www.youtube.com/watch?v=u\_xKybPhcHI
- OpenCL on FPGAs Accelerating Performance and Design Productivity Altera http://www.youtube.com/watch?v=M6vpq6s1h A

•

# **Summary**

| 1 | Intr | oduction                      | . 2 |
|---|------|-------------------------------|-----|
| 2 | Tera | asic DE1-SoC board            | . 3 |
|   | 2.1  | Specifications                |     |
|   | 2.2  | Layout5                       |     |
| 3 | Сус  | lone V Overview               | . 6 |
| 4 | SoC  | part test                     | . 7 |
|   | 4.1  | HPS Architecture              |     |
|   | 4.2  | Hardware development          |     |
|   | 4.2. | 1 Qsys integration            |     |
|   | 4.3  | Software development          |     |
|   | 4.3. | 1 ARM DS-5 tools              |     |
|   | 4.3. | 2 Hello World on ARM HPS part |     |
|   | 4.3. | 3 GPIO access                 |     |

# **List of Figures**

| Fig. 1. | Fig style                               | Error! Bookmark not defined. |
|---------|-----------------------------------------|------------------------------|
| Fig. 2. | Test program for specific parallel port | Error! Bookmark not defined. |